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AMENDMENTS TO THE CLAIMS: 

Claim 1 . (Currently amended) A method of maintaining the order of nodes in a hierarchical 
document, comprising: 

selecting a first parameter corresponding to a selected maximum number of children for 
each node for an auxiliary ordered tree; 

selecting a second parameter corresponding to a selected minimum number of children 
for each node of the for an auxiliary ordered tree; 

building the auxiliary ordered tree having at least as many leaves as atoms within said 
hierarchical document based upon the first and second parameters; 

attaching the atoms to the leaves of said auxiliary ordered tree; and 

labeling each of the nodes in the auxiliary ordered tree ; and 

communicating the labeled nodes of the auxiliary ordered tree to a user, 

wherein said labels comprise integer numbers having a size that is bounded by said first 
parameter and said second parameter . 



Claim 2. (Original) The method of claim 1, wherein the labeling of the nodes in the 
auxiliary tree is defined by: 

N(root) = 0; 
N(x) = N(y) + i 3 (f - l) h(x) ; and 
0<i<f 

Where: 

N(x) is the label for node x; 
x is the i* child ofy; 

f is the maximum number of children per node; and 
h(x) is the height of node x. 

Claim 3. (Original) The method of claim 1, further comprising assigning labels to the 
atoms in the hierarchical document based upon the labels assigned to the corresponding leaves 
in the auxiliary ordered tree. 
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Claim 4. (Original) The method of claim 1, further comprising storing the labels of the 
leaves of the auxiliary ordered tree. 

Claim 5. (Original) The method of claim 4, further comprising storing the remaining 
portion of the auxiliary ordered tree. 

Claim 6. (Original) The method of claim 1, further comprising partitioning the auxiliary 
ordered tree into a first portion that comprises the leaves from the auxiliary ordered tree and a 
second portion that comprises the remaining portion of the auxiliary ordered tree. 

Claim 7. (Currently amended) The method of claim 1, further comprising re-assigning 
labels to the atoms in the hierarchical document based upon the labels assigned to the 
corresponding leaves in the updat e d auxiliary ordered tree. 

Claim 8. (Withdrawn) A method of updating an auxiliary ordered tree having at least as 
many leaves as atoms within a hierarchical document based upon a selected maximum number of 
children for each node and a selected minimum number of children for each node, comprising: 

receiving a request to insert the hierarchical document with a new atom at specific 
position; 

inserting a new leaf in the auxiliary ordered tree based on the specific position of the 
corresponding atom in the hierarchical document; 

searching for the highest ancestor node of the new leaf that has a number of leaves that 
equals or exceeds the selected maximum number of leaves; 

if no ancestor is found that equals or exceeds the selected maximum number of leaves 
then re-labeling the sub-tree rooted at the parent node of the new leaf; 

if an ancestor node is found that has a number of leaves that equals or exceeds the 
selected maximum number of leaves, then 

determining whether the ancestor node is the root node; 
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if the ancestor node is the root node, then creating a new root having a 
predetermined number of children; 

if the ancestor node is not the root node, then splitting the ancestor node into 
complete sub-trees that have the same leaf sequence as the ancestor node's sub-tree; and 

reassigning labels in a top-down fashion in the sub-tree rooted at the parent of the 
ancestor node. 

Claim 9. (Withdrawn) The method of claim 8, wherein the predetermined maximum 
number of leaves is defined as: 

L m ax(t) = s3(f/S) h(t) 

Where: 

f is a predetermined maximum fanout; and 
s is a predetermined split factor. 

Claim 10. (Withdrawn) The method of claim 8, wherein said insertion request comprises a 
request to insert a plurality of consecutive atoms and wherein said updating minimizes the cost 
of inserting the new leaves that correspond to the plurality of consecutive atoms. 

Claim 11. (Withdrawn) The method of claim 10, wherein the plurality of consecutive atoms 
comprise a plurality of tags and text segments. 

Claim 12. (Withdrawn) The method of claim 8, further comprising: 

receiving a request to delete an atom in the hierarchical document at a specific position; 

and 

marking the corresponding leaf in the auxiliary ordered tree as deleted. 

Claim 13. (Withdrawn) The method of claim 12, further comprising: 

determining whether the sub-tree of an ancestor node that equals or exceeds a 
predetermined maximum number of leaves has a sub-tree with a deleted leaf; and 



10/629,744 

DOCKET NO. YOR920030239US1 



5 



inserting a new leaf in place of the deleted leaf 

Claim 14. (Currently amended) A method of optimizing the cost of maintaining the order of 
nodes in a hierarchical document using an auxiliary ordered tree having at least as many leaves 
as atoms within a hierarchical document, the shape of the auxiliary ordered tree being based 
upon a selected maximum number of children for each node and a selected minimum number of 
children for each node, the method comprising: 

adjusting the maximum number of children for each node and the selected minimum 
number of children for each node of the auxiliary ordered tree based upon application 
requirements regarding one of update cost, total cost of queries and updates, and the size of the 
labels ; and 

communicating the adjusted auxiliary ordered tree to a user, wherein the nodes of said 
auxiliary ordered tree have numerical labels according to a recursive formula and the leaves in a 
label tree correspond to the nodes in a corresponding XML tree in pre-order traversal . 

Claim 15. (Currently amended) A method of encoding an auxiliary ordered tree having at least 
as many leaves as atoms within a hierarchical document, the shape of the auxiliary ordered tree 
being based upon a selected maximum number of children for each node and a selected 
minimum number of children for each node, the method comprising! 
minimizing space requirements using a virtual tree ; and 

communicating the encoded auxiliary ordered tree to a user, wherein the nodes of said 
auxiliary ordered tree have numerical labels according to a recursive formula and the leaves in a 
label tree correspond to the nodes in a corresponding XML tree in pre-order traversal . 

Claim 16. (Currently amended) A system for maintaining the order of nodes in a hierarchical 
document, comprising: 

means for selecting a first parameter corresponding to a selected maximum number of 
children for each node for an auxiliary ordered tree; 

means for selecting a second parameter corresponding to a selected minimum number of 
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children for each node for an auxiliary ordered tree; 

means for building the auxiliary ordered tree having at least as many leaves as atoms 

within said hierarchical document based upon the first and second parameters; 

means for attaching the atoms to the leaves of said auxiliary ordered tree; and 

means for labeling each of the nodes in the auxiliary ordered tree^ 

wherein said labels comprise integer numbers having a size that is bounded by said first 

parameter and said second parameter . 

Claim 17. (Original) The system of claim 16, wherein the means for labeling each of the 
nodes bases the labeling upon: 

N(root) = 0; 
N(x) = N(y) + i3(f- l) h(x) ; and 
0<i<f 

Where: 

N(x) is the label for node x; 
x is the I th child of y; 

f is the maximum number of children per node; and 
h(x) is the height of node x. 

Claim 18. (Original) The system of claim 16, further comprising means for storing the labels 
of the leaves of the auxiliary ordered tree. 

Claim 19. (Original) The system of claim 18, further comprising means for storing the 
remaining portion of the auxiliary ordered tree. 

Claim 20. (Original) The system of claim 16, further comprising means for partitioning the 
auxiliary ordered tree into a first portion that comprises the leaves from the auxiliary ordered tree 
and a second portion that comprises the remaining portion of the auxiliary ordered tree. 
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Claim 21. (Original) The system of claim 16, further comprising means for re-assigning 
labels to the atoms in the hierarchical document based upon the labels assigned to the 
corresponding leaves in the updated auxiliary ordered tree. 

Claim 22. (Currently amended) A recording medium storing a program for making a 
computer maintain the order of nodes in an hierarchical document, the program comprising: 

instructions for selecting a first parameter corresponding to a selected maximum number 
of children for each node for an auxiliary ordered tree; 

instructions for selecting a second parameter corresponding to a selected minimum 
number of children for each node for an auxiliary ordered tree; 

instructions for building the auxiliary ordered tree having at least as many leaves as 
atoms within said hierarchical document based upon the first and second parameters; 

instructions for attaching the atoms to the leaves of said auxiliary ordered tree; and 

instructions for labeling each of the nodes in the auxiliary ordered tree , wherein said 
labels comprise integer numbers having a size that is bounded by said first parameter and said 
second parameter . 

Claim 23. (Original) The medium of claim 22, wherein the instructions for labeling each of 
the nodes is based upon: 

N(root) = 0; 
N(x) = N(y) + i3(f-l) h(x) ; and 
0<i<f 

Where: 

N(x) is the label for node x; 
x is the i th child of y; 

f is the maximum number of children per node; and 
h(x) is the height of node x. 



Claim 24. 



(Original) The medium of claim 22, further comprising instructions for assigning 
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labels to the atoms in the hierarchical document based upon the labels assigned to the 
corresponding leaves in the auxiliary ordered tree. 

Claim 25. (Original) The medium of claim 22, further comprising instructions for storing the 
labels of the leaves of the auxiliary ordered tree. 

Claim 26. (Original) The medium of claim 25, further comprising instructions for storing the 
remaining portion of the auxiliary ordered tree. 

Claim 27. (Original) The medium of claim 22, further comprising instructions for 
partitioning the auxiliary ordered tree into a first portion that comprises the leaves from the 
auxiliary ordered tree and a second portion that comprises the remaining portion of the auxiliary 
ordered tree. 

Claim 28. (Original) The medium of claim 22, further comprising instructions for re- 
assigning labels to the atoms in the hierarchical document based upon the labels assigned to the 
corresponding leaves in the updated auxiliary ordered tree. 

Claim 29. (Withdrawn) A system for updating an auxiliary ordered tree having at least as 
many leaves as atoms within a hierarchical document based upon a selected maximum number of 
children for each node and a selected minimum number of children for each node, comprising: 

means for receiving a request to insert the hierarchical document with a new atom at 
specific position; 

means for inserting a new leaf in the auxiliary ordered tree based on the specific position 
of the corresponding atom in the hierarchical document; 

means for searching for the highest ancestor node of the new leaf that has a number of 
leaves that equals or exceeds the selected maximum number of leaves; 

if no ancestor is found that equals or exceeds the selected maximum number of leaves 
then means for re-labelling the sub-tree rooted at the parent node of the new leaf; 
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if an ancestor node is found that has a number of leaves that equals or exceeds the 
selected maximum number of leaves, then 

means for determining whether the ancestor node is the root node; 

if the ancestor node is the root node, then means for creating a new root having a 
predetermined number of children; 

if the ancestor node is not the root node, then means for splitting the ancestor 
node into complete sub-trees that have the same leaf sequence as the ancestor node's sub- 
tree; and 

means for reassigning labels in a top-down fashion in the sub-tree rooted at the 
parent of the ancestor node. 

Claim 30. (Withdrawn) A recording medium storing a program for making a computer 
update an auxiliary ordered tree having at least as many leaves as atoms within a hierarchical 
document based upon a selected maximum number of children for each node and a selected 
minimum number of children for each node, comprising: 

instructions for receiving a request to insert the hierarchical document with a new atom at 
specific position; 

instructions for inserting a new leaf in the auxiliary ordered tree based on the specific 
position of the corresponding atom in the hierarchical document; 

instructions for searching for the highest ancestor node of the new leaf that has a number 
of leaves that equals or exceeds the selected maximum number of leaves; 

if no ancestor is found that equals or exceeds the selected maximum number of leaves 
then instructions for re-labeling the sub-tree rooted at the parent node of the new leaf; 

if an ancestor node is found that has a number of leaves that equals or exceeds the 
selected maximum number of leaves, then 

instructions for determining whether the ancestor node is the root node; 
if the ancestor node is the root node, then instructions for creating a new root 
having a predetermined number of children; 

if the ancestor node is not the root node, then instructions for splitting the ancestor 
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node into complete sub-trees that have the same leaf sequence as the ancestor node's sub- 
tree; and 

instructions for reassigning labels in a top-down fashion in the sub-tree rooted at 
the parent of the ancestor node. 



